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(57) Abstract: Methods and apparatus for 
efficiently enabling garbage collectors to 
be swapped into and out of virtual machine 
environments are disclosed. According to one 
aspect of the present invention, an interface for 
reclaiming memory in a multi-threaded virtual 
machine environment that has a virtual machine 
includes a first module that is associated with 
the virtual machine and a second module that is 
separate from the first module but interfaces with 
the first module. The first module includes a first 
routine for initiating a garbage collection process 
within the virtual machine environment, a second 
routine for scanning roots associated with the 
virtual machine environment, and a third routine 
for following roots through objects associated 
with the virtual machine environment The second 
module includes a fourth routine for initializing 
a heap in the virtual machine environment, a 
fifth routine for allocating an object in the virtual 
machine environment, and a sixth routine for 
performing the garbage collection process. In one 
embodiment, the second module also includes a 
seventh routine for implementing read and write 
barrios for the garbage collection process. 
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PATENT APPLICATION 

Method and Apparatus for Impijementing Modular Garbage 

Collectors 

background of the invention 

1 . Field of Invention 

The present invention relates generally to the performance of garbage 
5 collection in object-based systems. More particularly, the present invention relates to 
enabling different garbage collectors to be implemented for use with a virtual 
machine substantially altering the virtual machine to support each garbage collector. 

2. Description of the Related Art 

10 Within an object-based environment, threads are often used to satisfy requests 

for services. A thread may be thought of as a "sketch pad" of storage resources, and 
is essentially a single sequential flow of control within a computer program. In 
general, a thread, or a "thread of control," is a sequence of central processing unit 
(CPU) instructions or programming language statements that maybe independently 

15 executed. Each thread in a multi-threaded environment has its own execution stack 
on which method activations reside. As will be appreciated by those skilled in the art, 
when a method is activated with respect to a thread, an activation is "pushed" on the 
execution stack of the thread When the method returns, or is deactivated, the 
activation is "popped" from the execution stack. Since an activation of one method 

20 may activate another method, an execution stack operates in a first-in-last-out manner. 

While maintaining multiple threads, a computing Systran may need to perform 
global operations which require synchronization, or control of all threads or a set of 
threads at a given time. One example of such a global operation is garbage collection. 
25 As will be appreciated by those skilled in the art, garbage collection is a method 

which allows memory storage associated with objects which are no longer alive to be 
automatically reclaimed. 

1 
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Garbage collection generally occurs in two phases. A first phase typically 
involves identifying objects which are no longer needed or no longer in use, while a 
second phase renders the storage associated with the unneeded objects available for 
S reallocation. An object in a program is needed, or alive, at a given time if a program 
may access the object in the future. When an object is such that it will not be 
accessed in the future, the object is considered to be unneeded or dead Garbage 
collection algorithms, or "garbage collectors," typically consider an object to be dead 
substantially only when a program has abandoned all pointers to the object, making 
10 future access to the object inq>ossible. 

Within systems which use garbage collectors, eg. , within systems which 
include virtual machines, when it is desired for a garbage collector to be modified or 
replaced with another garbage collector, the virtual machine itself must also be 

15 modified to support the modified or replacement garbage collector. At times, it may 
be desirable to replace an existing garbage collector in a system with a different 
garbage collector to improve the efficiency of garbage collection and, hence, the 
performance of the system. Typically, the process of altering or changing a garbage 
collector is time-consuming as it often requires substantial modifications be made to 

20 the virtual machine to accommodate the altered or new garbage collector. 

Therefore, what is desired is a relatively inexpensive method and apparatus for 
enabling a garbage collector associated with a virtual machine to either be modified or 
changed Specifically, what is needed is a method and an apparatus for enabling 
25 garbage collectors to be efficiently swapped into and swapped out of virtual machine 
systems. 

SUMMARY OF THE INVENTION 

3 0 The present invention relates to methods and apparatus for enabling modular 

garbage collectors to be swapped into and swapped out of virtual machines without 



2 



WO 01797042 



PCT/DS01/18465 



requiring that the virtual machines be altered. According to one aspect of the present 
invention, an interface for reclaiming memory in a multi-threaded virtual machine 
environment that has a virtual machine includes a first module that is associated with 
the virtual machine and a second module that is separate from the first module but 
5 interfaces with the first module. The first module includes a first routine for initiating 
a garbage collection process within the virtual machine environment, a second routine 
for scanning roots associated with the virtual machine environment, and a third 
routine for following roots through objects associated with the virtual machine 
environment The second module includes a fourth routine for initializing a heap in 
10 the virtual machine environment, a fifth routine for allocating an object in the virtual 
machine environment, and a sixth routine for performing the garbage collection 
process. In one embodiment, the second module also includes a seventh routine for 
implementing read and write barriers for the garbage collection process. 

IS These and other advantages of the present invention will become apparent 

upon reading the following detailed descriptions and studying the various figures of 
the drawings. 



HRTHF nrac wnON OF THE DRAWINGS 

20 

The invention may best be understood by reference to the following 
description taken in conjunction with the accompanying drawings in which: 

Figures 1 A and IB are a diagrammatic representation of an environment 
25 which supports pluggable garbage collectors in accordance with an embodiment of 
the present invention. 

Figure 2 is a process flow diagram that illustrates the steps associated with the 
overall operation of a virtual machine in accordance with an embodiment of the 
30 present invention. 
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Figure 3 is a process flow diagram that illustrates the steps associated with 
performing a garbage collection, eg., step 212 of Figure 2, in accordance with an 
embodiment of the present invention. 

5 Figure 4 is a diagrammatic representation of a memory space in accordance 

with an embodiment of the present invention. 

Figure 5 is a diagrammatic representation of a general-purpose computer 
system suitable for implementing the present invention. 

10 

Figure 6 is a diagrammatic representation of a virtual machine suitable for 
implementing the present invention. 

mrrATTjgn dr scjuption of the embodiments 

15 

hi the following description, numerous specific details are set forth in order to 
provide a thorough understanding of the present invention. It will be apparent, 
however, to one skilled in the art that the present invention may be practiced without 
some or all of these specific details. In other instances, well known structures or 
20 operations have not been described in detail in order to not unnecessarily obscure the 
invention. 

A garbage collection framework which enables different garbage collectors to 
be developed and readily '^plugged into" the framework without requiring changes to 
25 be made to a virtual machine increases the flexibility of systems which use the 
garbage collectors. For example, an improved garbage collector may be readily 
implemented in an existing system to increase the efficiency with which the system 
operates, thereby increasing overall system performance. 

30 In one embodiment, a virtual machine environment maintains a memory 

system substantially separately from a virtual machine, and separates common 
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garbage collection routines, e.g., scanning routines, from algorithm-specific routines. 
To enable garbage collectors to be plugged into a virtual machine environment 
without affecting a virtual machine, algorithm-specific garbage collection routines 
may be maintained separately from common or shared garbage collection routines. 

5 

Figure 1 A is a diagrammatic representation of an environment which enables 
garb age collectors to be swapped in and swapped out without requiring that a virtual 
machine be altered in accordance with an embodiment of the present invention. An 
environment 102, e.g., a virtual machine environment, includes a virtual machine 104 
1 0 and a memory system 106 that is substantially separated from virtual machine 104. 
One example of a virtual machine will be described below with reference to Figure 6. 
Allowing memory system 106 to be substantially separated from virtual machine 104 
facilitates the ability to use different garbage collectors interchangeably with respect 
to environment 102. 

15 

Memory system 106 includes shared garbage collector code 108 which 
enables substantially any specific garbage collector, as for example garbage collector 
112, to be implemented with respect to memory system 106. The use of shared 
garbage collector code 108 enables specific garbage collectors, such as specific 
20 garbage collectors 1 12 and 1 14, to be used substantially interchangeably with respect 
to virtual machine 1 04 without requiring modifications to be made to virtual machine 
104. As shown in Figure IB, specific garbage collector 114 maybe used to perform 
garbage collection on memory system 106 in lieu of specific garbage collector 1 12. 

25 In order for garbage collectors 112 and 114 to be substantially pluggable , 

garbage collectors 1 12 and 1 14 are written to interface with shared garbage collector 
code 108. Hence, as long as garbage collectors 112 and 114 are consistent with 
shared garbage collector code 108, garbage collectors 1 12 and 1 14 may be 
implemented without modifying virtual machine 104. 

30 
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In addition to shared garbage collector code 1 08, code associated with 
memory system 106, Le., memory system code, which may be used by a virtual 
machine generally includes code that initializes heaps and allocates object Shared 
garbage collector code 108 which is intended to be used by substantially any suitable 
5 garbage collection implementation may include, but is not limited to, code which 
stops thread execution at garbage collection safe points, code that identifies and scans 
exact roots, code that finds and scans references in obj ects or arrays, and code that 
handles special objects and cases. The special objects and cases may include weak 
references, finalization, string interning, and class uploading. 

10 

Although the virtual machine environment in which modular or pluggable 
garbage collectors are used may be widely varied, in the described embodiment, the 
virtual machine environment is a Java™ virtual machine environment, developed by 
Sun Microsystems, Inc. of Palo Alto, California. In a Java™ environment, shared 

IS garbage collection interfaces or routines which a modular or pluggable garbage 
collection implementation, e.g. 9 a developer-written implementation, uses may 
include, but are not limited to, a <t CVMgcStopTheWorldAndGCO" routine which 
effectively initiates a garbage collection, a "CVMgcScanRootsO" routine which scans 
for exact garbage collection roots, a "CVMobj ectWalkRefe(obj , callback)" routine 

20 which walks through objects, and "CVMgcScanSpecialO" and 

"CVMgcProcessSpedalWithLivenessInfoO" routines which are arranged to handle 
special objects. If a garbage collection implementation utilizes such routines, then the 
garbage collection implementation, e.g. 9 a specific garbage collector, may be 
efficiently plugged into a virtual machine environment 

25 

A specific garbage collection implementation that is pluggable will generally 
include algorithm-specific garbage collection code. Each garbage collection 
implementation may have its own type of heap layout, its own heap initialization 
process, and its own heap teardown process. Algorithm-specific code may also have 
30 specific object allocation processes, specific object reclamation algorithms, and 
specific read and write barriers. By way of example, the read and write barriers 
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associated with generational garbage collectors may be specified in algorithm-specific 
code, and are substantially unaffected by the associated virtual machine environment 
In one embodiment, if no implementation of read and write barriers are provided by 
algorithm-specific code, the barriers are considered to be empty. 

5 

In general, in order for algorithm-specific garbage collection code to be 
recognized by shared garbage collection code once the algorithm-specific garbage 
collection code is interfaced with the shared garbage collection code, routines 
associated with the algorithm-specific code have names which are specified by die 

10 share garbage collection code. Within a Java™ environment, for example, an 

algorithm-specific heap initialization routine maybe expected to be implemented as a 
"CVMgccimpInitHeapO" process. In other words, the shared garbage collection code 
may be arranged to make a call to a "CVMgccimpInitHeapO" method in order to 
initialize a heap. Similarly, an algorithm-specific object allocation routine may be 

IS expected to be implemented as a "CVMgcimplAllocObj ect(size)" method, and an 
algorithm-specific garbage collection performed once threads are stopped may be 
expected to be implemented as a "CVMcimplGCQ" method, hi addition, an 
algorithm-specific read barrier may be expected to be implemented as either a 
"CVMgcin^)IReadBarrierRefO M method or a "CX^dn^lReadBarrieKI^" method, 

20 while an algorithm-specific write barrier may be expected to be implemented as either 
a "CVMgcimpWriteBanieiRefl3 ,t method or a *t^^gcnnplWriteBarri«<r>" 
method. 

Figure 2 is a process flow diagram which illustrates the steps associated with 
25 the overall operation of a virtual machine in accordance with an embodiment of die 
present invention. A virtual machine allocates memory in step 204. In general, a 
virtual machine may allocate memory to obj ects as needed using a memory allocator. 
When there is insufficient memory to allocate objects, then the memory allocator 
typically decides to perform a garbage collection in order to reclaim memory space in 
30 step 208. Reclaiming memory space using a garbage collection, as will be 

appreciated by those skilled in the art, typically involves reclaiming memory space 



7 



WO 01797042 



PCT/US01/18465 



allocated to objects which may no longer be accessed As will be appreciated by 
those skilled in the art, when a memory allocator decides to perform a garbage 
collection, a safe-point typically must be reached within the overall environment 
before a global operation, such as a garbage collection, which requires 
5 synchronization is performed 

Id step 212, a garbage collection is performed In the described embodiment, 
performing a garbage collection includes allowing shared garbage collection code, 
e,g. , code that is shared by different garbage collectors, to interact with specific 
10 garbage collection code, e.g., garbage collection code associated with a specific 
garbage collector. One method of performing garbage collection will be described 
below with respect to Figure 3. After the garbage collection is performed, then 
process flow returns to step 204 in which the virtual machine is allowed to continue to 
allocate memory. 

15 

Referring next to Figure 3, one method of performing garbage collection using 
a pluggable or modular garbage collector which includes shared code, eg., code 
associated with a virtual machine, and code that is specific to the garbage collector 
will be described in accordance with an embodiment of the present invention. That is, 
20 step 212 of Figure 2 will be described A garbage collection begins at step 304 in 
which garbage collector specific code calls shared code to stop all threads at garbage 
collection points for the threads, e.g, at thread-specific safe-points. 

All threads are stopped at the appropriate garbage collection points by the 
25 shared code in step 308. At garbage collection points, each thread of a system polls 
for garbage collection using, for example, method call points and backward branches 
in die shared code. In one embodiment, a thread at a garbage collection point may 
save its garbage collector scannable state and suspend itself. 

30 After all threads are stopped, then the shared code calls the specific code in 

step 3 12 to free up a predetermined number of bytes. In step 320, die specific code 
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scans roots by calling methods included in the shared code. Hie roots may be 
scanned in order to process special roots by walking through the memory on which 
garbage collection is being performed. Once the roots are scanned, the specific code 
performs a sweep through the memory by calling shared code in step 324. The sweep 
5 enables the predetermined number of bytes to be freed, and the garbage collection is 
competed. 

The garbage collector used to perform the garbage collection described in 
Figure 3 is a mark and sweep garbage collector, as will be appreciated by those skilled 
10 in the art In general, the pluggable garbage collector of the present invention may be 
substantially any suitable garbage collector, and is not limited to being a mark and 
sweep garbage collector. 

In one embodiment, a generational garbage collector may be a garbage 
15 collector which is suitable for swapping into and swapping out of the system. A 
generational garbage collector may be used with respect to a memory space which is 
divided into a "young" space and an "old" space. Figure 4 is a diagrammatic 
representation of a memory space in accordance with an embodiment of the present 
invention. Within a memory space 402 or a heap, a division may be made to separate 
20 the memory space into a "young" space 406 and an "old" space 410. A root set 418 
includes roots 422, eg, exact roots, which reference objects 414 in memory space 
402. 



Within memory space 402, young space 406 is used for new object allocation, 
25 while old space 410 is used for tenured, or long-standing, objects 414, eg., objects 
414e-g. That is, young space 406 is associated with a relatively young generation of 
objects 414 while old space 410 is associated with a relatively old generation of 
objects 414. A generational garbage collector which performs garbage collection 
within memory space 402 typically copies older objects 414 from young space 406 
30 into old space 410, then removes those objects 414 that were copied from young 
space 406, Le. , reclaims memory from young space 406 that was associated with 
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objects 414 which were copied A generational garbage collector would also remove 
dead objects 414, e.g. 9 objects 414f and 414g, from both young space 406 and old 
space 410, as appropriate. 

5 In one embodiment, different garbage collectors may be used to perform 

garbage collection on young space 406 and old space 410. Specifically, in addition to 
being able swap different generational garbage collectors into and out of a system 
without modifying virtual machine code, young space 406 and old space 4 1 0 may 
each have a different pluggable garbage collector. A garbage collection framework 

1 0 may enable generational garbage collection code to be shared by individual garbage 
collectors for young space 406 and old space 410. The shared garbage collection code 
may be arranged to coordinate the timing between the individual garbage collectors, 
or the specific code associated with each individual garbage collector, that may be 
independently maintained. For example, the shared code may determine a point in 

IS time daring which at least one of the individual or independent garbage collectors 
should perform a particular action. 

A shared interface for substantially pluggable generational garbage collectors 
may effectively invoke garbage collectors for each space or generation, eg:, a young 

20 generation or an old generation, based on need. For example, if a young space or 
generation is full, then the shared interface may invoke a garbage collection on the 
young space. As will be understood by those skilled in the art, most objects die 
young. Hence, with respect to Figure 4, young space 406 is typically small in relation 
to old space 410. Garbage collection is, therefore, performed on young space 406 

25 more frequently than it is performed on old space 410. Accordingly, the amount of 
time spent on garbage collection may be reduced by implementing garbage collections 
independently on young space 406 and old space 410 on an as-needed basis. 



Figure 5 illustrates a typical, general-purpose computer system suitable for 
30 implementing the present invention. The computer system 1030 includes at least one 
processor 1 032 (also referred to as a central processing unit, or CPU) that is coupled 
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to memory devices including primary storage devices 1036 (typically a read only 
memory, or ROM) and primary storage devices 1034 (typically a random access 
memory, or RAM). 

5 Computer system 1030 or, more specifically, CPUs 1032, may be arranged to 

support a virtual machine, as will be appreciated by those skilled in the art One 
example of a virtual machine that maybe supported on computer system 1030 will be 
described below with reference to Figure 6. As is well known in the art, ROM acts to 
transfer data and instructions uni-directionally to the CPUs 1032, while RAM is used 

10 typically to transfer data and instructions in a bi-directional manner. CPUs 1032 may 
generally include any number of processors. Both primary storage devices 1034, 
1036 may include any suitable computer-readable media. A secondary storage 
medium 1038, which is typically a mass memory device, is also coupled bi- 
directionally to CPUs 1032 and provides additional data storage capacity The mass 

15 memory device 1038 is a computer-readable medium that may be used to store 
programs including compute code, data, and the like. Typically, mass memory 
device 1038 is a storage medium such as a hard disk or a tape which generally slower 
than primary storage devices 1034, 1036. Mass memory storage device 1038 may 
take the form of a magnetic or paper tape reader or some other well-known device. It 

20 will be appreciated that the information retained within the mass memory device 
1 03 8, may, in appropriate cases, be incorporated in standard fashion as part of RAM 
1036 as virtual memory. A specific primary storage device 1034 such as a CD-ROM 
may also pass data uni-directionally to fte CPUs 1032. 

25 CPUs 1032 are also coupled to one or more input/output devices 1040 that 

may include, but are not limited to, devices such as video monitors, trade balls, mice, 
keyboards, microphones, touch-sensitive displays, transducer card readers, magnetic 
or paper tape readers, tablets, styluses, voice or handwriting recognizers, or other 
well-known input devices such as, of course, other computes. Finally, CPUs 1032 

30 optionally may be coupled to a computer or telecommunications network, e.g., an 
internet network or an intranet network, using a network connection as shown 
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generally at 1012. With such a network connection, it is contemplated that the CPUs 
1032 might receive information from the network, or might output information to the 
network in the course of performing the above-described method steps. Such 
information, which is often represented as a sequence of instructions to be executed 
5 using CPUs 1032, maybe received from and outputted to the network, for example, 
in the form of a computer data signal embodied in a carrier wave. The above- 
described devices and materials will be familiar to those of skill in the computer 
hardware and software arts. 

10 As previously mentioned, a virtual machine may execute on computer system 

1030. Figure 6 is a diagrammatic representation of a virtual machine which is 
supported by computer system 1030 of Figure 5, and is suitable for implementing the 
present invention. When a computer program, eg. , a computer program written in the 
Java™ programming language, is executed, source code 11 10 is provided to a 

15 compiler 1 120 within compile-time environment 1 105. Compiler 1120 translates 

source code 11 10 into bytecodes 1130. In general, source code 11 10 is translated into 
bytecodes 1130 at the time source code 1110 is created by a software developer. 

Bytecodes 1 130 may generally be reproduced, downloaded, or otherwise 
20 distributed through a network, e.g. y network 1012 of Figure 5, or stored on a storage 
device such as primary storage 1034 of Figure 5. In the described embodiment, 
bytecodes 1 130 are platform independent That is, bytecodes 1130 maybe executed 
on substantially any computer Systran that is running on a suitable virtual machine 
1140. 

25 

Bytecodes 1130 are provided to a runtime environment 1135 which includes 
virtual machine 1 140. Runtime environment 1 135 may generally be executed using a 
processor or processors such as CPUs 1032 of Figure 5. Virtual machine 1 140 
includes a compiler 1 142, an interpreter 1 144, and a runtime system 1 146. Bytecodes 
30 1130 may be provided either to compiler 1 142 or interpreter 1 144. 
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When bytecodes 1 130 are provided to compiler 1 142, methods contained in 
bytecodes 1 130 are compiled into machine instructions. In one embodiment, 
compiler 1 142 is a just-in-time compiler which delays the compilation of methods 
contained in bytecodes 1130 until the methods are about to be executed When 
5 bytecodes 1130 are provided to interpreter 1144, bytecodes 1130 are read into 

interpreter 1 144 one bytecode at a time. Interpreter 1144 then performs the operation 
defined by each bytecode as each bytecode is read into interpreter 1 144. That is, 
interpreter 1 144 "internets" bytecodes 1 130, as will be appreciated by those skilled in 
the art hi general, interpreter 1144 processes bytecodes 1130 and performs 
10 operations associated with bytecodes 1 130 substantially continuously. 

When a method is invoked by another method, or is invoked from runtime 
environment 1 135, if the method is interpreted, runtime system 1 146 may obtain the 
method from runtime environment 1135 in the form of a sequence of bytecodes 1130, 

15 which may be directly executed by interpreter 1 144. I£ on the other hand, the method 
which is invoked is a compiled method which has not been compiled, runtime system 
1146 also obtains the method from runtime environment 1 135 in the form of a 
sequence of bytecodes 11 30, then may go on to activate compiler 1142. Compiler 
1 142 then generates machine instructions from bytecodes 1 1 30, and the resulting 

20 machine-language instructions may be executed directly by CPUs 1032. In general, 
the machine-language instructions are discarded when virtual machine 1140 
terminates. Hie operation of virtual machines or, more particularly, Java™ virtual 
machines, is described in more detail in The Java™ Virtual Machine Specification by 
Tim Iindholm and Frank Yellin (ISBN 0-201-63452-X), which is incorporated herein 

25 by reference. 

Although only a few embodiments of the present invention have been 
described, it should be understood that the present invention may be embodied in 
many other specific forms without departing from the spirit or the scope of the present 
30 invention. By way of example, although the use of pluggable garbage collectors has 
been described as being suitable for use in a Java™ environment, pluggable garbage 
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collectors may be implemented for use in substantially any suitable environment 
Suitable environments include, but are not limited to, an environment which supports 
a Smalltalk virtual machine. 

5 The interface between shared garbage collection code and algorithm-specific 

garbage collection code has been defined as including multiple routines or methods, 
some of which are part of shared garbage collection code and some of which are part 
of algorithm-specific garbage collection code. The names of routines and die number 
of routines associated with the interface, generally, may be widely varied For 
1 0 instance, additional routines such as routines which are specific to supporting 

different garbage collectors for different generations of memory may be added to the 
interface. 

In general, it should be appreciated that the steps associated with Ate various 
15 processes and methods of the present invention may be widely varied. For example, 
the steps associated with the methods may be altered or reordered Steps may also be 
replaced, removed, and added without departing from the spirit or (he scope of the 
present invention. Therefore, the present examples are to be considered as illustrative 
and not restrictive, and the invention is not to be limited to the details given herein, 
20 but may be modified within the scope of the appended claims. 
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CLAIMS 

What is claimed is: 

5 1. A computer-implemented interface for reclaiming memory in a multi-threaded 
virtual machine environment, the multi-threaded virtual machine environment 
including a virtual machine, the computer-implemented interface comprising: 

a first module, the first module being associated with the virtual machine, the 
first module including a first routine for initiating a garbage collection process within 
10 the virtual machine environment, a second routine for scanning roots associated with 
the virtual machine environment, a third routine for following roots through obj ects 
associated with the virtual machine environment; and 

a second module, the second module being separate from the first module, die 
second module being arranged to interface with the first module, the second module 
1 5 including a fourth routine for initializing a heap in die virtual machine environment, a 
fifth routine for allocating an object in the virtual machine environment, and a sixth 
routine for performing the garbage collection process. 

2. A computer-implemented interface according to claim 1 wherein the second 
20 module further includes at least a seventh routine for implementing barriers for the 

garbage collection process. 

3. A computer-implemented interface according to claim 2 wherein die barriers 
include a read barrier and a write barrier. 

25 

4. A computer-implemented interface according to claim 1 wherein the first 
module includes a seventh routine for handling particular objects associated with die 
virtual machine environment 
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5. A computer implemented method for reclaiming memory in a multi-threaded 
virtual machine environment, the multi-threaded virtual machine environment 
including a virtual machine, comprising: 

in a first module associated with the virtual machine* 
5 initiating a gaibage collection process within the virtual machine 

environment; 

scanning toots through obj ects associated with the virtual machine 

environment; 

following roots through objects associated with the virtual machine 

10 evironment; 

in a second module separate from the first module and arranged to interface 
with the first module, 

initializing a heap in the virtual machine environment; 
allocating an object in the virtual machine environment; and 
IS performing the gaibage collection process. 

6. A computer-implemented method according to claim 5 further comprising: 
in the second module, 

implementing barriers for the garbage collection process. 

20 

7. A computer-implemented interface according to claim 6 wherein the barriers 
include a read barrier and a write barrier. 

8. A computer-implemented interface according to claim 5 further comprising: 
25 in die first module, 
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handling particular objects associated with the virtual machine 
environment 

9. An apparatus for reclaiming memory in a multi-threaded virtual machine 
5 environment, the multi-threaded virtual machine environment including a virtual 

machine, comprising: 

in a first module associated with the virtual machine, 

a means for initiating a garbage collection process within the virtual 
machine environment; 
10 a means for scanning roots through obj ects associated with the virtual 

machine environment; 

a means for following roots through obj ects associated with the virtual 
machine evironment; 

in a second module separate from the first module and arranged to interface 
15 with the first module, 

a means for initializing a heap in the virtual machine environment; 
" a means for allocating an object in the virtual machine environment; 

and 

a means for performing the garbage collection process. 

20 

10. A computer-implemented method according to claim 9 farther comprising: 
in the second module, 

a means for implementing barriers for the garbage collection process. 
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11. A computer-implemented interface according to claim 1 0 wherein the barriers 
include a read/barrier and a write barrier. 

12. A computer-implemented interface according to claim 9 further comprising: 
5 in the first module, 

a means for handling particular objects associated with the virtual machine 
environment* 
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